home *** CD-ROM | disk | FTP | other *** search
/ Reverse Code Engineering RCE CD +sandman 2000 / ReverseCodeEngineeringRceCdsandman2000.iso / RCE / Ebooks / Thinking in Java / c16 / trash / Trash.java < prev   
Encoding:
Java Source  |  2000-05-25  |  4.9 KB  |  133 lines

  1. //: Trash.java
  2. //////////////////////////////////////////////////
  3. // Copyright (c) Bruce Eckel, 1998
  4. // Source code file from the book "Thinking in Java"
  5. // All rights reserved EXCEPT as allowed by the
  6. // following statements: You can freely use this file
  7. // for your own work (personal or commercial),
  8. // including modifications and distribution in
  9. // executable form only. Permission is granted to use
  10. // this file in classroom situations, including its
  11. // use in presentation materials, as long as the book
  12. // "Thinking in Java" is cited as the source. 
  13. // Except in classroom situations, you cannot copy
  14. // and distribute this code; instead, the sole
  15. // distribution point is http://www.BruceEckel.com 
  16. // (and official mirror sites) where it is
  17. // freely available. You cannot remove this
  18. // copyright and notice. You cannot distribute
  19. // modified versions of the source code in this
  20. // package. You cannot use this file in printed
  21. // media without the express permission of the
  22. // author. Bruce Eckel makes no representation about
  23. // the suitability of this software for any purpose.
  24. // It is provided "as is" without express or implied
  25. // warranty of any kind, including any implied
  26. // warranty of merchantability, fitness for a
  27. // particular purpose or non-infringement. The entire
  28. // risk as to the quality and performance of the
  29. // software is with you. Bruce Eckel and the
  30. // publisher shall not be liable for any damages
  31. // suffered by you or any third party as a result of
  32. // using or distributing software. In no event will
  33. // Bruce Eckel or the publisher be liable for any
  34. // lost revenue, profit, or data, or for direct,
  35. // indirect, special, consequential, incidental, or
  36. // punitive damages, however caused and regardless of
  37. // the theory of liability, arising out of the use of
  38. // or inability to use software, even if Bruce Eckel
  39. // and the publisher have been advised of the
  40. // possibility of such damages. Should the software
  41. // prove defective, you assume the cost of all
  42. // necessary servicing, repair, or correction. If you
  43. // think you've found an error, please email all
  44. // modified files with clearly commented changes to:
  45. // Bruce@EckelObjects.com. (Please use the same
  46. // address for non-code errors found in the book.)
  47. /////////////////////////////////////////////////
  48.  
  49. // Base class for Trash recycling examples
  50. package c16.trash;
  51. import java.util.*;
  52. import java.lang.reflect.*;
  53.  
  54. public abstract class Trash {
  55.   private double weight;
  56.   Trash(double wt) { weight = wt; }
  57.   Trash() {}
  58.   public abstract double value();
  59.   public double weight() { return weight; }
  60.   // Sums the value of Trash in a bin:
  61.   public static void sumValue(Vector bin) {
  62.     Enumeration e = bin.elements();
  63.     double val = 0.0f;
  64.     while(e.hasMoreElements()) {
  65.       // One kind of RTTI:
  66.       // A dynamically-checked cast
  67.       Trash t = (Trash)e.nextElement();
  68.       val += t.weight() * t.value();
  69.       System.out.println(
  70.         "weight of " +
  71.         // Using RTTI to get type
  72.         // information about the class:
  73.         t.getClass().getName() +
  74.         " = " + t.weight());
  75.     }
  76.     System.out.println("Total value = " + val);
  77.   }
  78.   // Remainder of class provides support for
  79.   // prototyping:
  80.   public static class PrototypeNotFoundException
  81.       extends Exception {}
  82.   public static class CannotCreateTrashException
  83.       extends Exception {}
  84.   private static Vector trashTypes = 
  85.     new Vector();
  86.   public static Trash factory(Info info) 
  87.       throws PrototypeNotFoundException, 
  88.       CannotCreateTrashException {
  89.     for(int i = 0; i < trashTypes.size(); i++) {
  90.       // Somehow determine the new type
  91.       // to create, and create one:
  92.       Class tc = 
  93.         (Class)trashTypes.elementAt(i);
  94.       if (tc.getName().indexOf(info.id) != -1) {
  95.         try {
  96.           // Get the dynamic constructor method
  97.           // that takes a double argument:
  98.           Constructor ctor =
  99.             tc.getConstructor(
  100.               new Class[] {double.class});
  101.           // Call the constructor to create a 
  102.           // new object:
  103.           return (Trash)ctor.newInstance(
  104.             new Object[]{new Double(info.data)});
  105.         } catch(Exception ex) {
  106.           ex.printStackTrace();
  107.           throw new CannotCreateTrashException();
  108.         }
  109.       }
  110.     }
  111.     // Class was not in the list. Try to load it,
  112.     // but it must be in your class path!
  113.     try {
  114.       System.out.println("Loading " + info.id);
  115.       trashTypes.addElement(
  116.         Class.forName(info.id));
  117.     } catch(Exception e) {
  118.       e.printStackTrace();
  119.       throw new PrototypeNotFoundException();
  120.     }
  121.     // Loaded successfully. Recursive call 
  122.     // should work this time:
  123.     return factory(info);
  124.   }
  125.   public static class Info {
  126.     public String id;
  127.     public double data;
  128.     public Info(String name, double data) {
  129.       id = name;
  130.       this.data = data;
  131.     }
  132.   }
  133. } ///:~